<template>
  <el-dialog
    title="评论信息"
    :append-to-body="true"
    :before-close="handleClose"
    close-on-click-modal
    v-model="dialogFormVisible"
  >
    <el-form
      status-icon
      v-if="dialogFormVisible"
      ref="form"
      label-width="120px"
      :model="form"
      label-position="labelPosition"
      style="margin-left: -35px; margin-bottom: -35px; margin-top: 15px"
    >
      <el-form-item label="用户" prop="nickname">
        <span>{{ form.user_info != null ? form.user_info.nickname : '' }}</span>
      </el-form-item>
      <el-form-item label="评论内容" prop="text">
        <span v-html="text"></span>
      </el-form-item>

      <el-form-item label="状态" prop="is_audit">
        <el-radio v-model="form.is_audit" :label="true">审核通过</el-radio>
        <el-radio v-model="form.is_audit" :label="false">拉黑</el-radio>
        <!-- <el-input size="medium" v-model="form.is_audit"></el-input> -->
      </el-form-item>
    </el-form>
    <template #footer>
      <div class="dialog-footer">
        <el-button type="default" @click="handleClose">取 消</el-button>
        <el-button type="primary" @click="confirmEdit('form')">确 定</el-button>
      </div>
    </template>
  </el-dialog>
</template>

<script>
import commentApi from '../../model/comment'
import Utils from '@/lin/util/util'
export default {
  name: 'CommentDialog',
  data() {
    return {
      dialogFormVisible: false,
      loading: false,
      form: {
        id: 0,
        avatar: '',
        is_audit: true,
        text: '',
      },
    }
  },
  computed: {
    text() {
      return Utils.formatHtml(Utils.formatHyperLink(this.form.text))
    },
  },
  methods: {
    show(record) {
      Object.assign(this.form, record)
      this.dialogFormVisible = true
    },

    async confirmEdit(formName) {
      this.$refs[formName].validate(async valid => {
        if (valid) {
          this.loading = true
          const res = await commentApi.editComment(this.form.id, this.form.is_audit).finally(() => {
            this.loading = false
          })
          this.dialogFormVisible = false
          this.$message.success(`${res.message}`)
          this.$emit('ok')
        } 
      })
    },
    handleClose() {
      this.dialogFormVisible = false
    },
  },
}
</script>

<style lang="scss" scoped></style>
